草庐IT

Dev Box 服务

全部标签

走。在服务器程序中获取错误 i/o 超时

我编写了简单的服务器程序来从客户端接收数据。我有点不明白有时我从函数中得到错误readtcp4IP:PORTi/otimeoutint,err:=conn.Read([]byte)未超过函数SetDeadline()中设置的事件时间。我展示了我的部分代码,但我认为这就足够了。我接收数据的主循环如下。c:=NewClient()c.kickTime:time.Now()func(c*Client)Listen(){durationToClose:=time.Minute*time.Duration(5),c.conn.SetDeadline(c.kickTime.Add(c.durati

javascript - Websocket 握手失败 404(golang 服务器)

我有一个简单的goweb服务器,它在端口localhost:8080上提供一个公共(public)文件夹,其中包含一个html文件以及一个带有websocket逻辑的客户端脚本。在我的main.gofilelistener,err:=net.listen("tcp","localhost:8080")iferr!=nil{log.Fatal(err)}//fullcodeingisthttps://gist.github.com/Kielan/98706aaf5dc0be9d6fbe然后在我的客户端脚本中try{varsock=newWebSocket("ws://127.0.0.1:

file - 去)我如何进行下载服务?

关闭。这个问题需要更多focused.它目前不接受答案。想改进这个问题吗?更新问题,使其只关注一个问题editingthispost.关闭6年前。Improvethisquestion我做上传服务器但是我不能做下载服务器packagemainimport("fmt""io""os""github.com/gin-gonic/gin")funcuploadHandler(c*gin.Context){uid:=c.Request.FormValue("uid")file,header,err:=c.Request.FormFile("uploadFile")filename:=heade

golang windows服务包初始化设置

我正在尝试使用这个包创建一个golangwindows服务godoc.org/golang.org/x/sys/windows/svc一切正常,直到我添加一个初始化函数来初始化设置。然后服务无法启动。我试图通过这个包加载config.jsongithub.com/spf13/viper我得到的错误是:无法启动服务:服务没有及时响应启动或控制请求。 最佳答案 @JimB谢谢。就是这样,在调试中运行它会在exe所在的文件夹中查找,在服务中运行时,它会在system32文件夹中查找。我安装了github.com/kardianos/ose

audio - 如何让服务器在收到请求时播放声音

我想让服务器在每次收到请求时播放一段声音。如果我使用基于Go的服务器,有没有办法做到这一点?这个想法是服务器托管一个浏览器窗口,它收到一个请求,然后浏览器发出“ping!”。 最佳答案 这取决于您希望代码在哪个操作系统上运行。Afaik没有用于从go播放声音的通用跨平台解决方案:在Linux上,您可能需要依赖PulseAudio和一个软件包,例如github.com/mesilliac/pulse-simple在Windows和Mac上,您可以将PortAudio与诸如github.com/gordonklaus/portaudio

android - Android 应用通过 post 发送的参数在 Go 语言编写的后端服务器上始终为空

我正在尝试通过在Android应用程序中使用SendUserIdTokenToBackend()方法来发布token。privateclassSendUserIdTokenToBackendextendsAsyncTask{privateExceptionexception;@OverrideprotectedStringdoInBackground(String...idToken){Log.d(TAG,"idToken"+idToken);try{Listparams=newArrayList();Pairpair=Pair.create("idToken",idToken[0])

ruby-on-rails - 我可以从不同的服务器进程编写和利用 memcached 吗?

假设您有一个Rails应用程序,并且您已经在使用排队(resque)来卸载服务器上一些缓慢/非紧急的处理。排队处理执行Rails应用程序所需的一些功能-然后将信息保存到内存缓存存储中......一切都很好。但是是否可以编写一个由运行go应用程序的队列触发的组件,该应用程序反过来利用与Rails应用程序相同的底层数据库并写入相同的内存存储?这很常见吗?不是那么琐碎吗?Rails和Go都熟悉数据库模式,虽然Go应用程序可能有一些重复的业务逻辑,但它非常孤立。将其视为一种逐渐将在Rails中运行的某些服务器功能迁移到在Go中运行的方法。这是在实践中完成的吗? 最佳

go - rpc Call 方法是否在与服务器相同的 go routine 中运行?

我的服务器:func(t*Arith)Multiply(args*Args,reply*int)error{*reply=args.A*args.Breturnnil}funcmain(){arith:=new(Arith)rpc.Register(arith)rpc.HandleHTTP()l,e:=net.Listen("tcp",":1234")ife!=nil{log.Fatal("listenerror:",e)}gohttp.Serve(l,nil)}客户:client.Call("Arith.Multiply",args,&reply)我认为Multiply在另一个gor

http - Golang http 服务器实现

我读过net/http为每个连接启动一个go子例程。我有几个问题。但是我还没有看到任何参数来限制生成的新go子程序的数量。例如,如果我每秒要处理100万个并发请求,会发生什么情况?我们对生成的go子程序有任何控制吗?如果它为每个连接生成一个go子程序,它不会阻塞我的整个系统吗?为go网络服务器处理大量并发请求的推荐方法是什么?我必须处理异步和同步两种响应情况。 最佳答案 Job/Worker模式是一种很常见的适合此任务的并发模式。多个goroutine可以从单个channel读取,在CPU内核之间分配一定量的工作,因此称为worke

linux - Golang 的 net.LookupHost() 是否使用 "/etc/resolv.conf"中的所有 DNS 服务器?

我有一个应用程序,它是用Go编写的,使用了这个函数,但它总是无法解析DNS名称。我可以使用其他应用程序很好地解析服务器上的DNS名称,但不能使用使用此功能的基于Go的应用程序。 最佳答案 如有疑问,请“使用来源,卢克”。读书dnsclient_unix.go显示它遍历所有已配置的服务器。但请注意://IfanswererroredforrcodesdnsRcodeSuccessordnsRcodeNameError,//itmeanstheresponseinmsgwasnotusefulandtryinganother//serv